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(54) Web interfacing device 

(57) Web access functionality is embedded in a 
device (10) comprising a web server (14) providing 
access to the user interface functions for the device (10) 
through a device web page (18), and a network inter- 
face (12) in the device (10) enabling access to the »'et 
page (18) by a web browser (40) such that a user of the 
web browser (40) accesses the user interface functions 
for the device (10) through the web page (18). 
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The present invention pertains to the field of user interfaces for devices. More particularly, this invention relates to 
embedding web access functionality into devices to provide enhanced and widely accessible user interface functions 

s A w.de variety of devices including office equipment, home-based equipment, and lab equipment, as well as a vari- 

ety of other types of devices commonly provide device specific user interface functions. Such devices may also be 
referred to as gadgets. Office equipment includes, for example, printers, fax machines, copiers, and-various types of 
commun.cat.on and telephony devices. Home-based devices include home entertainment equipment such as televi- 
s.ons and video and audio players and recorders as well as security systems, automobiles, appliances, thermostats, 

io and ho tubs. Lab equipment includes measurement devices such as oscilloscopes, spectrum analyzers and other 
types of measurement equipment as well as networking equipment. 

The user-interface mechanisms of such devices commonly include relatively simple and low cost user input and 
display mechanisms. Such simple mechanisms may include, for example, light emitting elements such as LED/LCD ele- 
ments as well as various types of simple input buttons or switches. Such simple mechanisms are typically constructed 
* be °w «« to minimize the overall cost of such devices. In addition, such mechanisms are usually compact and ena- 

™ f ^ S ?S fof *"* d6ViCeS - Un,ortunate ly. such simple user interface mechanisms severely limit the 
range and flexibility of the user interface functions provided by such devices 

intJ? ^ er ' in to^ce functions of such a device may be enhanced by the implementation of a screen-based user 
interface mechanism w,th,n the device. For example, such a device may include a display screen, and a rendering proc- 
essor afong with appropriate software for generating a rich graphical user interface suitable for the particular type of 
JZ h T' TO"™ diSPl3yS renderin9 mechanisms are expensive and increase the overall cost 
^ 9 00515 3re typiCa " y unsuitaWe for ,ower c «s* devices targeted for a relatively large mass market 
Moreover, display screens and associated hardware may be too bulky for the size constraints of many devices 

device maX^n^ ** 3 USi " 9 3 " eXternal «* °** m f** 

~! be ™ nn{ f 10 computer system through either a standard connection such as a serial or parallel port 
connect.on or through a specialized hardware interface. The external computer system usually executes a set of soft- 

ZtfL^Z^T* « ^ if*** t0 thS ^ The extemal computer SyStem ™y dement a screen- 

. ^ eXtemal eon,puter System also execute web server "ftware that enables 
external web browsers to access the computer system and in turn the user interface of the device 

faro w^hT *. 5UC ^ an eXtefnal COmpUter SyStem 9reaUy increases the 0051 of P^ing a screen-base user inter- 
£2 .nLTdf 5 ' Pri ° r COmpUter SyStem based solutions dually require the development of special- 
ized software for each particular type of device. Moreover, such specialized software for a particular device from a 
EXZSZ ufacturer must typically be developed for differing types cf computer system p.atfornS SuSTvaS^ 
TZV^ntlT"^ *T? 9reatl/ C ° mPliCateS thS teSk ° f pr0VidinQ SUbb ° rt to^e devices. Furthermore. 

The 15321^^ accesstole. low cost, and enhanced user interface functions for a device is disclosed, 

web oaoeTe J ^ 9 ** ^ ,unctiona,itv into the device including a web server that provides a device 
browsed A ! r „H °^ 30 MtM0 * that enables access t0 the device web page by a web 

ThTwIh ™ f ? Z ' aCC6SSeS 816 ^ interfaCe ,m ctions for the device through the devtee web page 
The web server funct.onal.ty may be implemented with existing circuitry in a device, such as an exiting orocessoV mem 

required for dedicated web server hardware for the device 

n ™ S "J"?™ totality embedded in the device enables device user interface access via a variety of commu- 
EZL m2f ' ndUd,n9 W ° rW WWe W6D P 0 *" ° f ,he lnternet - ^he costs of providing screen based user 
2XJTSTZ!£ ^ ^ ^ ^ d ° n0t r6qUire an exte ™' «W to provide a d^e 

vatt of^es^^™^ "! d,5Cl05ed herei ° Pr0Vide SCfeen ^ user-friendly interfaces to a wide 
SeiSo^l arS ^ J* 6 ' 0 " 6XPen5iVe hM * w- a " d SOftWare for differing devices. 

^^^^^^T"? W * ,eChn ° l09y 50 that access t0 • **» user interface is independent 
the loS of the^T ^ y -"dependent of the web browser software executed and independent of 

a ™ 6 user interface information is packaged using the Hyper-Text Markup Language (HTML) and is transoorted 

nS 21 1 ? n tt ' e Plat,0rm tha< 6XeCUteS web browser " "The P r esent techniques avoid the 
oS 3 J i2 ' ■ w ' de w Ap P |lcat,on Programming Interface (API) to unify the control and use of equipment 
32 JaUT 0< the P^ent ^ntion will be apparent from the detailed deSiption It follows 

a^re^r^^r respect to — — — - 
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(54) Web interfacing device 

(57) Web access functionality is embedded in a 
device cjO) comprising a web server (14) providing 
access to the user interface functions for the device (10) 
through a device web page (18). and a network inter- 
face (12) in the device (10) enabling access to the web 
page (1 8) by a web browser (40) such that a user of the 
web browser (40) accesses the user interface functions 
for the device (10) through the web page (18). 
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Figures 1 a-1 b illustrate a device with embedded web access functionality that provides device-specific user inter- 
face functions through a device web page; 

Figure 2 shows a home-based network that enables a web browser to access the user interface functions through 
the device web page; 

Figure 3 illustrates an example device web page for a printer device; 

Figure 4 shows a large organization network or intranet that enables access to the device web pages of differing 
' devices; 

Figure 5 illustrates access to device web pages through the Internet world-wide web. 

Figure 1a illustrates a device 10 with embedded web access functionality that provides device-specific user inter- 
face functions. The device 10 includes a network interface 12 and a web server 14 along with a monitor 1 6. The network 
interface 12 enables communication via a communication path 22. The monitor 16 controls various device-specific func- 
tions of the device 10 and monitors a set of information pertaining to the device 10 via a control/monitor path 20. The 
web server 1 4 provides web server functions to web orients via the communication path 22. The web server 1 4 provides 
web server functions according to the Hyper-Text Transfer Protocol (HTTP). 

The web server 14 receives HTTP commands through the network interface 12 that specify a predetermined Uni- 
versal Resource Locator (URL) for the device 10. The HTTP commands may be used by web clients to read information 
from the device 10 such as device status information. The HTTP commands may also be used to transfer information 
to the device 10 such as information that controls the functions or operating states of the device 10 Such HTTP com- 
mands include HTTP GET, HTTP POST, and HTTP PUT commands. 

In response to an HTTP command targeted for the device 10, the web server 14 generates a web page 18 that 
defines a set of user interface functions for the device 10. The web page 18 is a Hypertext Markup Language (HTML) 
file. The network interface 12 transfers the web page 18 to a requesting HTTP client via the communication path 22. 

The web server 14 generates the web page 18 dynamically to reflect the updated state of the information pertaining 
to the device 10 that is maintained by the monitor 16. The web page 18 may also define control buttons according to 
the HTTP protocol that enable various control functions for the device 10 to be initiated from a web client via the com- 
munication path 22. The web page 18 may contain text, images, multimedia files, forms, tables or any object type sup- 
ported by the HTTP and HTML protocols. 

In addition, the web page 18 may contain one or more URLs that specify additional web pages located within the 
device 10. The web page 18 may also contain one or more URLs that specify additional web pages located elsewhere 
i.e. external to the device 1 0. The additional web pages external to the device 1 0 may be located, for example on a local 
communication network or on the Internet world wide web. 

The device 10 represents a wide variety of devices including devices such as printers, fax machines copiers com- 
munication and telephony devices, home entertainment devices such as televisions, video and audio devices as well 
as appliances such as refrigerators and washing machines, security systems, automobiles, and hot tubs The device 10 
also represents a variety of measurement instruments including oscilloscopes, and spectrum analyzers and other types 
of measurement devices. In addition, the device 10 represents a variety of computer peripheral devices including mass 
storage units such as rotating media storage units. 

The communication path 22 represents any communication means that is capable of transferring HTML files 
according to the HTTP web protocol. The communication path 22 may be realized by a wide variety of communication 
mechanisms including local area networks, telephone lines including cellular telephone links, serial communication 
links, parallel communication links, power line communication links, and radio and infrared communication links The 
communication path 22 may also be a direct Internet connection to the world-wide web. 

Figure 1b is a hardware block diagram of the device 10. The device 10 includes a processor 200 a memory 210 
a set of device-specific hardware 300 along with a set of input/output circuitry 220 that enables communication via the 
communication path 22. The processor 200 performs device-specific functions for the device 1 0 in combination with the 
device-specific hardware 300. The processor 200 is also employed to provide web server functionality in the device 10 
In one embodiment, the processor 200 stores the web page 18 in the memory 210 which may also be used to store 
information associated with normal device-specific functions. 

In one embodiment, the device 10 is a printer device wherein the processor 200 and the memory 210 preform 
image rendering functions and the device-specific hardware 300 includes printer hardware and associated circuitry and 
K^!l e ,nput/ou1 P ut drcuitr * 220 P rovid ^ network access to the printer device 10. The web server functionality is 
embedded into the printer device 10 by providing software or firmware for the processor 200 and by utilizing space 
available in the memory 210 and by using the existing input/output circuitry 220 such as Ethernet circuitry to transfer 
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HTML files. 

In another embodiment, the device 10 is a video player/recorder wherein the processor 200 and the memory 210 
perform functions for reading video and audio information from and writing video and audio information to a storage 
media such as magnetic tape or an optical storage media. The device-specific hardware 300 includes media actuation 
s hardware such as motors and magnetic heads and associated circuitry for reading and imparting information onto the 
storage media. The web server functionality is embedded into the video device 10 by providing software or firmware for 
the processor 200 and by utilizing space available in the memory 210 and by adding the input/output circuitry 220 to the 
video device 10. 

In yet another embodiment, the device 10 is a washing machine wherein the processor 200 and the memory 210 
w preform functions for controlling wash cycles. The device-specific hardware 300 includes hardware such as motors 
valves, sensors, and associated circuitry. The web server functionality is embedded into the washing machine 10 by 
prov.d.ng software or f .rmware for the processor 200 and by utilizing space available in the memory 210 and by adding 
the input/output circuitry to the video device 10. 

The web server functionality for the device 1 0 includes software executed by the processor 200 that services the 
is HTTP protocol and that generates HTML formatted files. The web page 18 in one embodiment is stored in the memory 
210 or may be generated on the fly. The processor 200 also executes communication software that drives the input/out- 
put circuitry 220 and provides the functionality of the netwqrk interface 1 2. In addition, the processor 200 executes soft- 
ware that performs control and information monitoring and logging functions of the monitor 16 

In another embodiment, the web server functions of the device 10 are implemented on a single integrated circuit 
zo chip including a processor and memory for holding software for servicing the HTTP protocol. In such an embodiment 
the hardware portion of the network interface 12 may be implemented on the same integrated circuit chip as the proc- 
essor or may be external to that chip. 

In yet another embodiment the web server functions of the device 1 0 are implemented with a state machine 
In another embodiment, thedevice 10 is a controller module or control computer contained in an automobile The 
input/output crcu.try 220 such as cellular transmitter/receiver circuitry enables a web browser to access control and sta- 
tus information for the automobile which is contained in the web page 18. 

In another embodiment, the device 10 is a mass storage device such as a disk drive or CD-ROM drive The 
input/outout circuitry 220 such as local area network interface circuitry enables a web browser to access control and 
status information for the mass storage device which is contained in the web page 18. 

In yet another embodiment the device 10 is a home-entertainment device such as an audio system. The input/out- 
put circuitry 220 such as infrared communication circuitry or power line communication circuitry enables a web browser 
such as a home computer to access control and status information for the audio system which is contained in the web 

p3Q6 1 o. 

The memory 210 may be a static memory such as read-only memory, a flash memory, or a disk drive or may be a 

volatHe memory such as a random access memory. The web page may be stored in the static memory or the random 

access memory in the HTML format or may be generated on the fly without being stored in the device 10 

_ " 9 . Ure * tT! a "ome-based network 30 that enables a web browser 40 to access the user interface functions of 

he device 10 The home-based network 30 maybe implemented with a variety of communication mechanisms suitable 

40 a ^ e M ^ POW6r G COmmunication links - ^ted Pair communication links, radio frequency communication 

40 ,,r, ks, and infrared communication links. 

anri I!T n r*, br0WSer t indU ? eS 3 diSP ' ay 42 f0f 9 enerati "9 visual objects including text, images, multimedia objects. 
* JJJ£S?.« ? T 1,16 br0WSef 40 indudes a se,ec,ion device 44 that a user to se.erf 

££ZE£t Si 8 fe T red 00 ,hC diSP ' ay 42 - ne WCb browser 40 ma * a,so indude an audi ° capability that ena- 
bles rendering of audio information to the user. 

m ^ ^me-based network 30 may also enable communication among a set of devices 50-52. The devices 50-52 

sTsteSfnd aPP,ianCeSl h ° me SSCUrity SySt6mS ' h0me entertainment devices, air-conditioning 
nS?H tUb J ° f thedevices 50-52 that implement the device web page mechanisms disclosed herein may 
provrfe device specific user interface web pages to the web browser 40 via the home-based network 30 

corn^r^r 5 * 40 66 in 3 COmputer ^em that executes a set of web browser software. Such a 

SZ£ SI S T TZ ftjnC I' 0nality ^ fealized by any ° ne 01 a of avai,ab,e computer system 
platforms including Windows platforms. Macintosh platforms. Unix platforms as well as any other platform capable of 
executing web browser software that provides HTTP client functions and that renders HTML files 

rer^™^ 

emer'sa'uRT^?^ T?? ? ™ ,UnCti0nS * the device 10 usin 9 web brows er 40. The user 

H * P imnt^S 0 ' 9 J° If d6V,Ce 10 ' nt0 thG W6b bf0WSer 40 res P° nse - me -eb browser 40 transfers an 
HTTP command which includes the entered URL over the home-based network 30. The device 10 receives the HTTP 
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command via the communication path 22 and recognizes the URL contained therein. 

In one embodiment, the information for the web page 1 8 is periodically updated by the processor 200 and is stored 
in HTML format in the memory 210. In such an embodiment, the processor 200 reads the web page 18 from the mem- 
ory 210 in response to the HTTP command and transfers the web page 18 to the web browser 40 via the home based 
network 30. 

In an alternative embodiment, the processor 200 generates the web page 18 on the fly in response to the HTTP 
command from the web browser 40. In such an embodiment, the processor 200 obtains information pertaining to the 
device from the device-specific hardware 300 after receiving the HTTP command and recognizing the URL contained 
therein. The processor 200 formats the information into the HTML format that defines the web page 18 and tracers 
the HTML formatted information to the web browser 40 via the home based network 30. 

The HTML file is transferred according to the HTTP protocol which specifies the URL corresponding to the web 
browser 40. The web browser 40 receives the HTML file and renders the web page 1 8 on the display 42. 

The following is an example HTML file that defines the web page 18 in an embodiment wherein the device 10 is a 
printer device. 



<TITLE>Printer Home Page</TITLE> 
<Hl>home page for device' 10</H1> 
<HR> 

The following information pertains to 
the device 10 which in this example 
is a printer 
<table border> 

<caption> Printer with a URL </caption> 
<TR> 

<TD>Printer Name</TD>Portdv9</TD> 

</TR> 
30 <TR> 

<TD>Administrator</TlxTD>Mr. John Doe</TD> 
</TR> 

<TR> 

<TD>Loc£tion</TD><TD>Building 1U</TD> 
</TR> 

< /TABLE > 

<P> 

40 <A HREF = "http://www.hpsc.com"> Service Contract </A> 

<P> 

<A HREF = "http://www.hpsupl.com"> Sucolies 
ordering</A> 
45 <P> 

<A HREF = "http://www.hpl.hp.com"> Future 

Products</A> 

<P> 

50 <HR> 
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Figure 3 illustrates the web page 1 8 for the example HTML file shown above wherein the device 1 0 is a printer The 
h "! ? 42 bV me WGb br0WSGr 40 in resp ° nse t0 the exam P le H ™ L code set forth 

Ml^^ M 3 ,it,G 7 °* 3 he3der SeCti ° n 60 ' 3 S6t ° f ASC " tGXt 62 ^ tab,e sectj ™ * 

The page title 70 is defined by the HTM L ( TITLE ) Printer Home Page ( /TITLE ) coding shown above. The header 
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section 60 is defined by the HTML code ( H1 ) Home Page for device 1 0< /H1 > in the HTML file shown above. The ASCII 
text 62 is the ASCII text contained in the HTML file shown above. The table section 64 is defined with coding in the 
HTML file shown above and provides information pertaining to the printer including a printer name, an administrator, 
and a location for the printer. 

The hyperlinks 66-68 defined in the HTML file shown above direct the web browser 40 to other web pages for var- 
ious printer support functions. For example, the hyperlink 66 "Service Contract" may be selected by the user with the 
selection device 44 to direct the web browser 40 to the URL "httpV/www.hpsc.com" for information regarding printer 
service contracts. Similarly, hyperlinks 67 and 68 provide links to web pages for ordering printer supplies and obtaining 
information for future printer products from the manufacturer of the printer device 10. 

The web page 18 for the printer may also include manuals, parts lists, and other associated publications. These 
publication may be stored within the device 10 in, for example, a nonvolatile memory, or may be referenced elsewhere 
via hyperlinks contained in the web page 18. These publications contain dynamic information such as updated manuals 
as well as new and updated software driver routines for the device 10. 

Figure 4 shows a large organization network 80 that enables access to the device web pages of the device 10 and 
the devices 50-52. The large organization network 80 may be referred to as an Intranet and may be implemented with 
a variety of communication mechanisms including local area networks connected together by various types of commu- 
nication links. 

Any one or more of a set of computer systems 90-92 eJoupled to the large organization network 80 may access the 
device web pages of the devices 10 and 50-52. The computer systems 90-92 may execute one or more of a*variety of 
available web browser software or may have web browser functions built in. 

A user of one of the computer systems 90-92 enters a URL corresponding to the desired one of the devices 1 0 and 
50-52 into the corresponding web browser application. In response, the particular web browser application as an HTTP 
client transfers an HTTP command that specifies the desired URL over the large organization network 80. The device 
specified by the HTTP command recognizes the URL contained therein. In response, the targeted device transfers an 
HTML file that defines its device web page via large organization network 80. The transfer of the HTML file specifies the 
URL of the originating HTTP client computer system from among the computer systems 90-92. The originating HTTP 
client computer system recognizes its URL and receives and then renders the device web page to the user. 

Figure 5 illustrates access to device web pages through a direct Internet connection to the world-wide web 100.. 
The web page 18 of the device 10 may be accessed by any web client on the world-wide web 100 including the web 
browser 40. 

In addition, a communication system 102 functions as a communication bridge between the world-wide web 100 
and a local area network 120 and a communication system 104 functions as a comrr.u. ncation bridge between the 
world-wide web 100 and a home base network 130. As a consequence, any other HTTP dients coupled to the local 
area network 120 or the home-base network 130 may access the device web pages in a device 108, a device 106, or 
the device 10. In addition, the web browser 40 or any HTTP client on the world-wide web 100 may access the device 
web pages of the devices 1 06 and 1 08. 

The embedded web server functionality described herein enables a variety of widely accessible device interroga- 
tion and control functions for a particular device as well as for sets of devices. For example, a web page may be embed- 
ded into each washing machine of a chain of Laundromats wherein an operator from an office computer can determine 
the machines that require servicing and schedule daily service routing to the Laundromats accordingly. 

The foregoing detailed description of the present invention is provided for the purposes of illustration and is not 
intended to be exhaustive or to limit the invention to the precise embodiment disclosed. Accordingly, the scope of the 
present invention is defined by the appended claims. 

Claims 

1 . A device ( 1 0) with an embedded web access mechanism, comprising: 

web server (14) that generates a device web page (18) wherein the device web page (18) provides a set of 
user interface functions for the device (10); 

network interface ( 1 2) that enables access to the device web page ( 1 8) by a web browser (40) such that a user 
of the web browser (40) accesses the user interface functions for the device (10) through the device web pace 
(18). ™ 

2. The device (10) of claim 1, wherein the web server (14) receives an HTTP command via the network interface (12) 
and then generates an HTML file that defines the device web page (18) in response to the HTTP command. 



3. A device (10). comprising : 
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processor (200) that generates a device web page (18) wherein the device web page (18) provides a set of 
user interface functions for the device (10) and includes a set of information pertaining to the device (10); 
memory (2 1 0) for storing the device web page ( 1 8) ; 

input/output circuitry (220) that enables communication via a communication path (22) such that a web 
5 browser (40) accesses the device web page (1 8) via the communication path (22). 

4. The device of claim 3. wherein the processor (200) receives an HTTP command via the input/output circuitry (220) 
and then generates an HTML file that defines the device web page (18) in response to the HTTP command. 

to 5. The device (1 0) as in claims 2 or 4, wherein the HTTP command specifies a URL corresponding to the device (10). 

6. The device (10) as in claim 2, wherein the HTML file contains a set of information pertaining to the device (10). 

7. The device (10) as in claims 2 or 4, wherein the HTML file contains a set of URLs that control a set of predeter- 
mined functions for the device (10) wherein each URL may point to a web page (18) located internal to the device 
(10) or a web page located external to the device (10). 

8. The device (10) as in claims 2 or 4, wherein the hYml file contains a hyperlink to an external web page that spec- 
ifies additional information pertaining to the device (10). 

9. A user interface method for a device (1 0), comprising the steps of: 

generating a device web page (18) within the device (10) wherein the device web page (18) provides a set of 
user interface functions for the device (10); 

providing access to the device web page (18) from a web browser (40) external to the device (1 0) such that a 
user of the web browser (40) accesses the user interface functions for the device (1 0) through the device web 
page (18). 

so ™7lS2?^? m V?* ^ * 9eneratin9 3 device web page < 18 > inc,udes the ste P of generating an 
HTML file that defines the dev.ce web page (18) in response to an HTTP command received from the web browser 

(40). 
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FIG. 1B 
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